//引入一个包
const path = require('path')
// 引入html插件
const HTMLWbpackPlugin = require("html-webpack-plugin")
//引入clean插件
const { CleanWebpackPlugin } = require('clean-webpack-plugin')
//webpack 中的所有的配置信息都应该写在module.exports中
module.exports = {

    //指定入口文件
    entry: './src/index.ts',

    //指定打包文件所在的目录
    output: {
        //指定打包文件的目录
        path: path.resolve(__dirname, 'dist'),
        // 打包后文件的文件
        filename: 'bundle.js',
        // 告诉webpack不使用箭头函数
        environment: {
            arrowFunction: false,
            const: false
        }
    },
    //指定webpack打包时要使用的模块
    module: {
        //指定要加载的规则
        rules: [
            {
                //指定规则生效的文件
                test: /\.ts$/,
                //要使用的loader
                use:
                    [
                        // 配置babel
                        {
                            // 指定加载器
                            loader: 'babel-loader',
                            // 设置babel
                            options: {
                                // 设置预定文件的环境
                                presets: [
                                    [
                                        //指定环境的插件
                                        "@babel/preset-env",
                                        // 配置信息
                                        {
                                            //要兼容的目标浏览器
                                            targets: {
                                                'chrome': '58',
                                                'ie': '11'
                                            },
                                            // 指定corejs的版本
                                            'corejs': '3',
                                            //使用corejs的方式
                                            // usage 表示按需加载
                                            'useBuiltIns': 'usage'
                                        }
                                    ]
                                ]

                            }
                        },
                        'ts-loader'
                    ],
                //要排除的文件
                exclude: /node_modules/
            },
            // 设置less文件的处理
            {
                test: /\.less$/,
                use: [
                    'style-loader',
                    'css-loader',
                    //引入postcss
                    {
                        loader: 'postcss-loader',
                        options: {
                            postcssOptions: {
                                plugins: [
                                    [
                                        'postcss-preset-env',
                                        {
                                            browsers: 'last 2 versions'
                                        }
                                    ]
                                ]
                            }
                        }
                    },
                    'less-loader'
                ]
            },

        ]
    },
    // --mode development[开发环境] 

    // --mode production[生产环境]
    mode: "production",
    //配置webpack插件
    plugins: [
        new CleanWebpackPlugin(),
        new HTMLWbpackPlugin({
            // title: '这是一个自定义的title'
            template: './src/index.html'
        })
    ],
    // 用来设置引用模块
    resolve: {
        extensions: ['.ts', '.js']

    }
}